## WHAT IS CLAIMED IS:

| 1   | 1. A processor comprising:                                                                                                                                                      |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | a replay system to replay instructions which have not executed properly;                                                                                                        |
| 3   | a first processing circuit coupled to the replay system to process instructions including any                                                                                   |
| 4   | replayed instructions;                                                                                                                                                          |
| 5   | a second processing circuit to perform additional processing on an instruction, the second                                                                                      |
| 6   | processing circuit having an ability to detect one or more faults occurring therein; and                                                                                        |
| 7   | a synchronization circuit coupled between the first processing circuit and the second                                                                                           |
| 8   | processing circuit to synchronize faults occurring in the second processing circuit to matching                                                                                 |
| 9   | instruction entries in the first processing circuit.                                                                                                                            |
| 1 2 | 2. The processor of claim 1 wherein the first processing circuit comprises a first event pipeline, and wherein the second processing circuit comprises a second event pipeline. |
| 1   | 3. A method comprising:                                                                                                                                                         |
| 2   | detecting that an instruction has not executed properly;                                                                                                                        |
| 3   | replaying an instruction in a first event pipeline;                                                                                                                             |
| 4   | performing additional processing on an instruction in a second event pipeline;                                                                                                  |
| 5   | detecting a fault for the instruction occurring in the second event pipeline;                                                                                                   |
| 6   | matching the instruction having a fault which occurred in the second event pipeline to an                                                                                       |
| 7   | instruction entry for the same instruction that is being replayed in the first event pipeline:                                                                                  |

| 8  | writing or tagging fault identification information for the fault to the matching instruction         |
|----|-------------------------------------------------------------------------------------------------------|
| 9  | entry in the first event pipeline.                                                                    |
|    |                                                                                                       |
| 1  | 4. A processor comprising:                                                                            |
| 2  | a replay system to replay instructions which have not executed properly;                              |
| 3  | a synchronous event pipeline coupled to the replay system to process instructions including           |
| 4  | any replayed instructions;                                                                            |
| 5  | an asynchronous event pipeline to perform additional processing on an instruction, the                |
| 6  | asynchronous event pipeline having an ability to detect one or more asynchronous faults occurring     |
| 7  | during the additional instruction processing; and                                                     |
| 8  | a synchronization circuit coupled between the synchronous event pipeline and the                      |
| 9  | asynchronous event pipeline to synchronize an asynchronous fault with a replayed instruction in the   |
| 10 | synchronous event pipeline.                                                                           |
|    |                                                                                                       |
| 1  | 5. The processor of claim 4 wherein the synchronization circuit comprises:                            |
| 2  | a buffer coupled to the asynchronous event pipeline for storing an instruction entry for an           |
| 3  | instruction having an asynchronous fault, the instruction entry including a sequence number and fault |
| 4  | identification information identifying the asynchronous fault; and                                    |
| 5  | a comparator coupled to the buffer and the synchronous event pipeline, the comparator                 |
| 6  | comparing a sequence number of an instruction entry in the synchronous event pipeline with the        |

sequence number of the instruction entry having the asynchronous fault, and writing the fault

7

| 8  | identification information of the asynchronous fault to the instruction entry in the synchronous event |
|----|--------------------------------------------------------------------------------------------------------|
| 9  | pipeline if a match is found.                                                                          |
|    |                                                                                                        |
| 1  | 6. The processor of claim 4 wherein the synchronization circuit comprises:                             |
| 2  | an input buffer coupled to the asynchronous event pipeline for storing an instruction entry            |
| 3  | for an instruction having an asynchronous fault, the instruction entry including a sequence number     |
| 4  | and fault identification information identifying the asynchronous fault;                               |
| 5  | an asynchronous fault buffer having age guarding logic coupled to the input buffer, the                |
| 6  | asynchronous fault buffer storing an instruction entry for an instruction having an asynchronous fault |
| 7  | in a temporary register; and                                                                           |
| 8  | a comparator coupled to the asynchronous fault buffer and the synchronous event pipeline,              |
| 9  | the comparator comparing a sequence number of an instruction entry in the synchronous event            |
| 10 | pipeline with a sequence number of the instruction entry stored in the temporary register of the       |
| 11 | asynchronous fault buffer, and writing the fault identification information of the asynchronous fault  |
| 12 | to the instruction entry in the synchronous event pipeline if a match is found.                        |
|    |                                                                                                        |
| 1  | 7. The processor of claim 6 wherein the asynchronous fault buffer comprises:                           |
| 2  | age guarding logic coupled to the input buffer; and                                                    |
| 3  | a temporary register coupled to the age guarding logic to store an instruction entry for an            |
| 4  | instruction having an asynchronous fault, the age guarding logic maintaining an oldest instruction     |
| 5  | entry in the register as compared between an instruction entry having an asynchronous fault already    |

| 6 | present in the temporary register and an instruction entry for an instruction having an asynchronous |
|---|------------------------------------------------------------------------------------------------------|
| 7 | fault stored in the input buffer.                                                                    |
|   |                                                                                                      |
| 1 | 8. The processor of claim 6 wherein the asynchronous fault buffer comprises:                         |
| 2 | age guarding logic coupled to the input buffer;                                                      |
| 3 | one or more temporary registers coupled to the age guarding logic to store one or more oldest        |
| 4 | instruction entries for an instruction having an asynchronous fault, the age guarding logic          |
| 5 | maintaining an oldest instruction entry in each temporary register as compared between an            |
| 6 | instruction entry having an asynchronous fault already present in the temporary register and an      |
| 7 | instruction entry for an instruction having an asynchronous fault stored in the input buffer; and    |
| 8 | a mux coupled to the one or more temporary registers for selectively outputting the                  |
| 9 | instruction entry from a selected temporary register to the comparator.                              |
|   |                                                                                                      |
| 1 | 9. The processor of claim 8 wherein there is one temporary register provided for each thread         |
| 2 | or program flow.                                                                                     |
|   |                                                                                                      |
| 1 | 10. A processor comprising:                                                                          |
| 2 | a replay system to replay instructions which have not executed properly;                             |
| 3 | a memory execution unit coupled to the replay system to execute load and store instructions,         |
| 4 | the memory execution unit including:                                                                 |

| 5  | a synchronous event pipeline to execute load or store instructions, including                          |
|----|--------------------------------------------------------------------------------------------------------|
| 6  | instructions which have been replayed;                                                                 |
| 7  | an asynchronous event pipeline coupled to the synchronous event pipeline for                           |
| 8  | performing additional processing on instructions, the asynchronous event pipeline having an ability    |
| 9  | to detect one or more asynchronous faults occurring during the additional instruction processing in    |
| 10 | the asynchronous event pipeline; and                                                                   |
| 11 | a synchronization circuit coupled between the synchronous event pipeline and the                       |
| 12 | asynchronous event pipeline to synchronize an asynchronous fault with a replayed instruction in the    |
| 13 | synchronous event pipeline.                                                                            |
|    |                                                                                                        |
| 1  | 11. The processor of claim 10 wherein said synchronization circuit comprises a comparator              |
| 2  | circuit to compare a sequence number of an instruction entry in the asynchronous event pipeline        |
| 3  | having a fault to sequence numbers of instruction entries in the synchronous pipeline, the comparator  |
| 4  | circuit writing fault identification information identifying the asynchronous fault to the instruction |
| 5  | entry in the synchronous event pipeline if a match is found.                                           |
|    |                                                                                                        |
| 1  | 12. A processor comprising:                                                                            |
| 2  | a replay system to replay instructions which have not executed properly;                               |
| 3  | a plurality of synchronous event pipelines coupled to the replay system to process                     |
| 4  | instructions including any replayed instructions;                                                      |

| 5    | an asynchronous event pipeline to perform additional processing on an instruction, the                     |
|------|------------------------------------------------------------------------------------------------------------|
| 6    | asynchronous event pipeline having an ability to detect one or more asynchronous faults occurring          |
| 7    | during the additional instruction processing in the asynchronous event pipeline;                           |
| 8    | a synchronization circuit coupled between the synchronous event pipeline and the                           |
| 9    | asynchronous event pipeline to synchronize an asynchronous fault with a replayed instruction in the        |
| 10   | synchronous event pipeline;                                                                                |
| 11   | a fault register; and                                                                                      |
| 12   | age guarding logic coupled between the plurality of synchronous event pipelines and the fault              |
| . 13 | register, the age guarding logic storing fault information in the fault register for an oldest instruction |
| 14   | entry as compared between the instruction entries from the plurality of synchronous pipelines and          |
| 15   | the fault information already present in the fault register.                                               |
|      |                                                                                                            |
| 1    | 13. The processor of claim 12 wherein the fault register stores fault information for an oldest            |
| 2    | instruction entry, the fault information including a specific fault code and an address.                   |
|      |                                                                                                            |
| 1    | 14. A method of processing faults in a processor comprising:                                               |
| 2    | detecting that an instruction has executed improperly;                                                     |
| 3    | replaying the instruction;                                                                                 |
| 4    | performing additional processing on the instruction;                                                       |
| 5    | detecting a fault in the additional instruction processing;                                                |
| 6    | writing fault identification information to an instruction entry for the replayed instruction.             |

| 1  | 15. The method of claim 14 wherein the writing fault identification information comprises                |
|----|----------------------------------------------------------------------------------------------------------|
| 2  | comparing a sequence number of the instruction entry for the replayed instruction with the               |
| 3  | sequence number of the instruction having the fault;                                                     |
| 4  | writing fault identification information to the instruction entry for the replayed instruction           |
| 5  | if there is a match.                                                                                     |
|    |                                                                                                          |
| 1  | 16. The method of claim 14 wherein said performing additional processing comprises                       |
| 2  | performing a long latency operation for the instruction in parallel with the instruction being replayed. |
|    |                                                                                                          |
| 1  | 17. A method comprising:                                                                                 |
| 2  | detecting that an instruction has executed improperly;                                                   |
| 3  | replaying the instruction in a synchronous event pipeline;                                               |
| 4  | performing additional processing on the instruction in an asynchronous event pipeline;                   |
| 5  | detecting an occurrence of an asynchronous fault during the additional processing of the                 |
| 6  | instruction in the asynchronous event pipeline;                                                          |
| 7  | identifying that the instruction in the asynchronous event pipeline having the fault matches             |
| 8  | the replayed instruction in the synchronous event pipeline; and                                          |
| 9  | writing fault identification information into an instruction entry for the replayed instruction          |
| 10 | in the synchronous event pipeline.                                                                       |

| 1  | 18. The method of claim 17 wherein said replaying comprises replaying the instruction ir                 |
|----|----------------------------------------------------------------------------------------------------------|
| 2  | one of a plurality of synchronous event pipelines.                                                       |
|    |                                                                                                          |
| 1  | 19. The method of claim 17 and further comprising storing fault identification information               |
| 2  | for an oldest instruction in a fault register as compared between the instruction entry in the           |
| 3  | synchronous event pipeline having the fault identification information and fault identification          |
| 4  | information already present in the fault register.                                                       |
|    |                                                                                                          |
| 1  | 20. An apparatus comprising:                                                                             |
| 2  | a replay system to replay instructions which have not executed properly;                                 |
| 3  | a first event pipeline;                                                                                  |
| 4  | a second event pipeline, the processor detecting a fault for an instruction in the second event          |
| 5  | pipeline;                                                                                                |
| 6  | a circuit coupled to the first and second event pipelines to add a fault identifier identifying          |
| 7  | the fault occurring in the second event pipeline to a corresponding instruction entry in the first event |
| 8  | pipeline when the instruction is replayed.                                                               |
|    |                                                                                                          |
| 9  | 21. An apparatus comprising:                                                                             |
| 10 | a replay system to replay instructions which have not executed properly;                                 |
| 11 | an age guarding circuit to add a fault identifier to an instruction entry for an instruction that        |
| 12 | is being replayed.                                                                                       |

- 1 22. The apparatus of claim 21 wherein the age guarding circuit adds a fault identifier for an
- 2 asynchronous or long latency fault occurring in an asynchronous event pipeline to a corresponding
- 3 instruction entry in a synchronous or short latency event pipeline.